WE CLAIM: 



1. A data array system for providing a host computer 
device having a host bus redundant access to a data storage 
device, comprising : 

an active controller linked to the host bus and the 
data storage device, the active controller including a 
messaging mechanism for transmitting the messages and data 
over the host bus; and 

a standby controller linked to the host bus and' the 
data storage device, the standby controller including 
message and data buffers for storing the messages and data, 
whereby the host bus functions as an inter-controller-link. 

2. The system of Claim 1, wherein the host bus is a 
peripheral component interconnect (PCI) bus. 

3. The system of Claim 2, wherein the active and the 
standby controllers are PCI-compliant devices. 

4. The system of Claim 1, wherein the standby 
controller includes a queue for storing a signal identifier 
and wherein the messaging mechanism of the active^ controller 
writes the signal identifier over the host bus to the 
standby queue to provide processing information for the 
transmitted messages and data. 

5. The system of Claim 4, wherein standby controller 
includes a messaging mechanism configured to process the 
signal identifier in response to an interrupt from the 
active controller and to process the stored messages . and 
data based on the signal identifier. 
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6. The system of Claim 5, wherein the signal 
identifier indicates the stored messages and data as a 
message-only transfer, a message-with-data transfer, or a 
message-with-partial data transfer. 

7. The system of Claim 6, wherein the standby 
messaging mechanism moves data in the data buffer to memory 
as part of the processing of the stored messages and data. 

8. The system of Claim 7, wherein the active 
controller includes a reply queue and the standby messaging 
mechanism replies to the transmitted messages and data by 
writing a reply message to the reply queue indicating 
messaging can be transmitted by the active controller. 

9. A method for providing inter-controller 
communications between an active controller and a standby 
controller configured for redundant communications between a 
host and a storage device and linked to a host bus, 
comprising: 

at the active controller, building a message; 

with the active controller, transferring the message to 
the standby controller; 

with the active controller, writing to a command/reply 
queue at the standby controller; 

with the standby controller, checking the command/reply 
queue for a next message; and 

upon detecting the next message, processing with the 
standby controller the transferred message. 

10. The method of Claim 9, further including driving 
an interrupt with the active controller to standby 
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controller and wherein the checking is performed in response 
to the standby controller sampling the interrupt. 

11. The method of Claim 10, further including with the 
active controller transferring data with the message, and 
wherein the transferred message indicates a presence or 
absence of the data. 

12. The method of Claim 11, wherein the message 
defines the data as all or partial and wherein the standby 
controller stores the data based on the all or partial 'data 
definition . 

13. The method of Claim 9, further including after the 
processing, with the standby controller writing to a reply 
queue at the active controller to indicate the processing is 
complete . 

14. A data storage system with redundant data storage, 
comprising : 

a host processor; 

an active controller controlling access by the host 
computer device to data storage devices; 

a standby controller controlling access by the host 
computer device to the data storage devices; and 

a host bus communicatively linking the host processor, 
the active controller, and the standby controller, wherein 
the active and standby controllers include redundancy 
messaging mechanisms configured to assert and sample signals 
on the host bus to provide inter-controller communications 
over the host bus. 
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15. The system of Claim 14, wherein the standby 
controller includes a command/reply queue for registering 
receipt of new messages and a message buffer for storing 
messages, and wherein the active redundancy mechanism 
transfers messages to the message buffer of the standby 
controller and writes to the command/reply queue to indicate 
the transmittal of the messages. 

16. The system of Claim 15, wherein the active 
redundancy mechanism asserts an interrupt to the standby 
controller over the host bus and the standby redundancy 
mechanism responds to the interrupt by checking the 
command/ reply queue . 

17. The system of Claim 14, wherein the standby 
controller includes a data buffer and wherein the active 
redundancy messaging mechanism transfers data corresponding 
to the message over the host bus to the data buffer. 

18. The system of Claim 17, wherein the standby 
redundancy messaging mechanism transfers the data from the 
data buffer to another memory device to enable receipt of 
additional data and transmits a signal to the active 
controller upon completion of the transfer of the data out 
of the data buffer. 

19. The system of Claim 18, wherein the signal 
includes writing to a reply queue at the active controller 
and transmitting an interrupt to the active controller. 
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20. The system of Claim 14, wherein the host bus is a 
peripheral component interconnect (PCI) bus and the active 
and standby controllers are PCI-compliant devices. 

21. A method for providing inter-controller 
communications between an active controller and a standby 
controller configured for redundant communications between a 
host and a storage device and linked to a host bus, 
comprising: • ^ 

at the standby controller, specifying a range of memory 
in the standby controller as an interrupt range; 

with the active controller, writing data to the 
interrupt range of the standby controller; and 

at the standby controller, driving a local interrupt. 

22. The method of Claim 21, wherein the interrupt 
driving is performed with a memory controller in the standby 
controller . 

23. The method of Claim 21, further including after 
the interrupt driving, with the standby controller writing 
to a reply queue at the active controller. 
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